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(57) A distributed computer system has a number 
of computers coupled thereto at distinct nodes. 
The computer at each node of the distributed 
system has a trusted computing base that in- 
cludes an authentication agent for authenticat- 
ing requests received from principals at other 
nodes in the system. Requests are transmitted 
to servers as messages that include a first 
identifier provided by the requester and a sec- 
ond identifier provided by the authentication 
agent of the requester node. Each server pro- 
cess is provided with a local cache of authenti- 
cation data that identifies requesters whose 
previous request messages have been authenti- 
cated. When a request is received, the server 
checks the request's first and second identifiers 
against the entries in its local cache. If there is a 
match, then the request is known to be authen- 
tic. Otherwise, the server node's authentication 
agent is called to obtain authentication creden- 
tials from the requester's node to authenticate 
the request message. The principal identifier of 
the requester and the received credentials are 
stored in a local cache by the server node's 
authentication agent The server process also 
stores a record in its local cache indicating that 
request messages from the specified requester 
are known to be authentic, thereby expediting 
the process of authenticating received re- 
quests. 
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The present invention relates generally to control- 
ling access to computer resources in a distributed 
computer system, and particularly to apparatus and 
methods for making such access control systems 
more efficient by locally caching in each computerau- 
thentication credentials for principals requesting use 
of that computer's resources. 

Computer security systems are often based on 
the basic access control model, which provides a 
foundation for secrecy and integrity security proce- 
dures. See, for example, the 1974 article by Butler 
Lampson, "ACM Operating System Reviews," Vol. 8, 
No.1, January 1974, pp. 18-24. The elements of this 
model are: 

- Objects, which are resources such as files, de- 
vices, or processes. 

- Requests to perform operations on objects. 

- Sources for requests, which are principals. 

- A reference monitor that examines each re- 
quest for access to a specified object and de- 
cides whether to grant it. 

The reference monitor bases its decision on the 
object, the principal making the request, the opera- 
tion in the request, and a rule that says what princi- 
pals may perform that operation. It should be under- 
stood that operation of the reference monitor is sep- 
arate and distinct from other security issues, such as 
whether a requestor is who he/she/it claims to be. 
That type of security is typically provided by using en- 
cryption and digital signature techniques, sometimes 
called authentication, as will be understood by those 
skilled in the art. The present invention is directed at 
a technique for making authentication of requesters 
more efficient. 

In general, in most prior art systems authenticat- 
ing each request by a requester requires digitally sign- 
ing the request, as well as an exchange of information 
called "credentials" between the requester and the 
server to enable the server to authenticate the digital 
signature on the request. The authentication process 
can impose significant overhead on the operation of 
distributed computer systems, especially when the 
number of requests transmitted between nodes is 
high. 

The invention in its broad form resides in security 
apparatus as in claim 1, and a method of operating a 
distributed computer system as recited in claim 7. Se- 
curity apparatus according to the invention is defined 
in claim 4. The dependent claims recite preferred fea- 
tures of the invention according to its various aspects. 
More particularly, described herein is a security sys- 
tem governing access to objects in a distributed com- 
puter system. The computer at each node of the dis- 
tributed system has a trusted computing base that in- 
cludes an authentication agent for authenticating re- 
quests received from principals at other nodes in the 
system. Requests are transmitted to servers as mes- 
sages that include a first identifier (called an Auth ID) 



provided by the requester and a second identifier pro- 
vided (called the subchannel value) by the authenti- 
cation agent of the requester node. Each server proc- 
ess has an associated local cache that identifies re- 

5 questers whose previous request messages have 
been authenticated. When a request is received, the 
server checks the request's first and second identifi- 
ers against the entries in its local cache. If there is a 
match, then the request is known to be authentic, 

10 without having to obtain authentication credentials 
from the requester's node, because the authentica- 
tion agents guarantee authenticity of such request 
messages. 

If the identifier in a request message does not 
15 match any of the entries in the server's local cache, 
then the server node's authentication agent is called 
to obtain authentication credentials from the request- 
er's node to authenticate the request message. Upon 
receiving the required credentials from the requester 
20 node's authentication agent, the principal identifier of 
the requester and the received credentials are stored 
in a local cache by the server node's authentication 
agent The server process also stores a record in its 
local cache indicating that request messages from 
25 the specified requester are known to be authentic, 
thereby expediting the process of authenticating re- 
ceived requests. 

A further optimization is that the server process 
local cache is used to store a list of the object access 
30 control list entries previously satisfied by each re- 
quester, thereby enabling the server process to expe- 
dite granting access to previously accessed objects. 

A more detailed understanding of the invention 
may be had from the following description of a prefer- 
35 red embodiment, given by way of example and to be 
understood in conjunction with the accompanying 
drawing wherein: 

Figure 1 is a block diagram a distributed computer 
system with a trusted naming service for storing 
40 secure data shared by the members of the sys- 
tem ; 

Figures 2 and 3 are block diagrams of one node 
of the distributed computer system shown in Fig- 
ure 1 ; 

45 Figure 4 is a block diagram of two computers, one 
having a requester process that is requesting ac- 
cess to a server process in the second comput- 
er; 

Figures 5A and 5B schematically depict an Au- 
50 thentication ID table and Channel Assignment Ta- 
ble maintained by authentication agents in the 
preferred embodiment of the present invention; 
Figure 6 schematically represents a data packet; 
Figure 7 schematically depicts a "local cache" of 
55 authentication data maintained by authentication 

agents in the preferred embodiment of the pres- 
ent invention; 

Figure 8 schematically depicts a local cache of 
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authentication data maintained on behalf of each 
server process in the preferred embodiment of 
the present invention; 

Figure 9 is a block diagram representing an ac- 
cess control list ; and 

Figure 10 is a flow chart of the authentication 

process performed by the authentication agents 

associated with a requester and a server. 

Referring to Figure 1, the present invention is a 
security system and method which typically operates 
in the context of a distributed computer system 100 
having a set of computers 102-1 to 102-N intercon- 
nected by a local or wide area network 110 or some 
other communications medium. Each of these com- 
puters 102 is said to be located at a distinct node of 
the distributed computer system 100. 

For the purposes of this document, we assume 
that the nodes are connected to each other by wires 
that are not physically secure. In the preferred em- 
bodiment, shared key encryption is used to secure 
channels between the nodes of the distributed sys- 
tem, and these channels are then multiplexed to ob- 
tain all the other channels needed by the network. 
Since the operating system at each node must be 
trusted anyway, using encryption at a finer grain than 
this (e.g., between processes) is not necessary. Al- 
ternately, public key encryption techniques could be 
used to secure the channels between nodes, al- 
though public key encryption is usually much slower 
than shared key encryption. 

Each computer 102 contains the standard com- 
puter system components, including a data process- 
ing unit (CPU) 112, system bus 114, primary (random 
access) memory 116, secondary storage 118 (e.g., 
magnetic or optical disks), virtual memory manager 
1 20, a user interface 122 (e.g., keyboard, monitor and 
printer) and network controller 124 for coupling the 
computer 102 to the network 110. A clock circuit 126 
or equivalent mechanism provides each computer 
1 02 with time values (used by the security apparatus 
discussed below). These physical computer compo- 
nents are not modified by the present invention and 
are therefore not described in detail herein. 

For convenience of schematic representation, 
the computer's operating system 130 is shown in Fig- 
ure 2 as being stored in primary memory, but as will 
be understood by those skilled in the art, portions of 
the operating system 130 are stored by the comput- 
er's virtual memory manager 120 in secondary mem- 
ory when not in use. The operating system 130 in- 
cludes a reference monitor 132 and authentication 
agent 134, both of which are discussed in more detail 
below. 

Also shown in Figure 2 is the (virtual) memory al- 
located to two processes, B1 and B2, Including appli- 
cation programs as well as data structures and soft- 
ware associated with the present invention. As will be 
understood by those skilled in the art, while the mem- 



ory space allocated to these processes is shown for 
convenience as being in primary memory, much of 
the memory space allocated to each process will be 
stored by the computer's virtual memory manager 

5 120 In secondary memory when not in use. 

Referring to Figure 3, one node 102-1 of the dis- 
tributed system is shown in more detail. Each node 
must have a trusted computing base (TCB) 135, 
which is typically a small amount of computer hard- 

10 ware and software that security depends on and that 
is distinguished from the remainder of the node, 
which can misbehave without affecting security. The 
TCB 135 includes a reference monitor program 132 
(sometimes called the reference monitor), which 

15 gathers the information needed to justify an access 
control decision. The reference monitor program 132 
runs within the address space of each process. The 
TCB 135 also includes an authentication agent 134, 
which in the present invention is a set of software in 

20 the computer's operating system that exchanges cre- 
dentials with the authentication agents of other 
nodes so as to authenticate the source of request, 
messages. The authentication agent 134 also per- 
forms a number of related tasks to ensure that mes- 

25 sages originated by processes at its node are tagged- 
or signed with valid sender identification data, as will 
be described below. 

The TCB 135 does not include the storage devic- 
es from which data is retrieved nor the transmission 

30 channels from which messages are received. This is 
because digitally signed messages can be fetched 
from unsecured places without any loss of confidence 
that the signer actually sent it originally. The details 
of encryption, decryption, and digital signatures and 

35 the like are not the subject of this document. These 
topics are widely discussed in the computer security 
literature. The present invention primarily concerns 
the authentication agent 134 and reducing the ex- 
change of credentials associated with authenticating 

40 messages sent between requesters and servers on 
different nodes of the distributed computer system. 

For the purposes of Figure 3, a process A1 in 
node 102-2 has been labelled "requester 0 because it 
is sends a request to one of the server processes B1 

45 to BN on node 102-1 . However, it should be noted that 
more generally the requester can be a principal using 
any one of the computers in the distributed system. 

A principal is herein defined to be the source of 
a request or assertion. Typically, one thinks of a prin- 

50 cipal as a person, or a machine acting on behalf of a 
person. However, processes many layers removed 
from human direction, such as those In a transaction 
processing system, can also be principals. 

Objects can be files, processes, set of data such 

55 as table or database, programs (e.g., an interface pro- 
gram which governs use of an input/output device), 
and so on. In the preferred embodiment, the objects 
136 to which access is governed by the reference 
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monitor program 1 32 on node 1 02-1 are stored in the 
computer at that node (other arrangements may be 
possible). Each object 136 includes an Access Con- 
trol List (ACL) 138 which defines the set of "princi- 
pals" who are authorized to access the object 1 36. 5 

Referring to Figure 4, each node of the distribut- 
ed system includes in its TCB an authentication agent 
134. In the context of Figure 4, we will consider the 
actions of the authentication agent 134 associated 
with process A1 on node 1 02-2 sending a request to 10 
a server process B1 on node 102-1. 

Prior to the sending of any requests between two 
nodes, a secure channel 140 between the two nodes 
must be established. One method of establishing a 
secure channel between two nodes is to have the two 15 
nodes establish a host-to-host key that will be used 
both to encrypt and decrypt all data packets transmit- 
ted between the two nodes. Data packets in the pre- 
ferred embodiment are encrypted using a private key 
encryption methodology, such as DES CBC. The pri- 20 
or art provides any number of mechanisms for distrib- 
uting encryption keys in a network. One such meth- 
odology developed at the Massachusetts Institute of 
Technology is known as KERBEROS. Other method- 
ologies are known as public key systems. In any case, 25 
in the context of the present invention, any two host 
computers that will transmit data packets therebetw- 
een must first agree on a "host-to-host" encryption 
key that will used to encrypt the secure portions of 
data packets transmitted between those two comput- 30 
ers. Furthermore, to ensure data integrity, a CRC er- 
ror detection code is included in each data packet, 
usually at the end of the data packet, for detecting 
corrupted packets as well as for detecting packets 
that may have been tampered with in an attempt to 35 
break the system's security provisions. Therefore 
each packet received by a node's network controller 
124 must be decrypted and error checked by a CRC 
(cyclic redundancy check) circuit before it can be used 
by the receiving host computer 102. 40 

Once a secure channel 140 has been establish- 
ed, all data packets sent over the secure channel 140 
by either node are routed through the sender's au- 
thentication agent 134. The authentication agent 134 
assigns a different virtual "subchannel* of the secure 45 
channel to each requester/server process pair for 
which a requester process on the authentication 
agenf s node transmit data packets to a server proc- 
ess on the other node. Subchannels are similar to 
process-to-process communication channels found 50 
in traditional operating systems. For example the In- 
ternet Transmission Control Protocol provides a bi-di- 
rectional connection between two processes. How- 
ever, in the present invention subchannels are imple- 
mented on top of node-to-node secure channels and 55 
authenticity guarantees can be made about the data 
which traverses them. Any given subchannel has two 
unique endpoints. The authentication agent at each 



endpoint guarantees the uniqueness of the endpoint 
it controls. Therefore, since an underlying node-to- 
node channel is implied, each endpoint can believe 
that all data received through the subchannel origin- 
ated at the unique node and process associated with 
the other endpoint of that subchannel. 

In the preferred embodiment, each principal as- 
sociated with the node 102 is assigned a distinct au- 
thentication identifier, herein called the Auth ID. Typ- 
ically, the assignment of the Auth ID to a principal is 
performed at the time that the principal logs into the 
system. It is possible for a single process A1 to do 
work on behalf of multiple principals, in which case 
each principal associated with the process will be giv- 
en a distinct Auth ID. 

Each node's authentication agent 134 maintains 
an Auth ID table 142, shown in Figure 5A, which lists 
the name of the principal and its assigned Auth ID. 
Each record in the table would typically also include 
other information, such as the name of the process 
that the principal is logged onto. 

Each node's authentication agent 134 also main- 
tains a Channel Assignment table 144, shown in Fig- 
ure 5B, which lists for each communication subchan- 
nel that has been assigned to a process, identifiers 
associated with the channel, subchannel, requester 
process and server process for which the subchannel 
is being used. 

Referring to Figure 6, each data packet 146 trans- 
mitted between nodes includes items provided by the 
process sending the data packet, and at least one 
field whose value is provided by the authentication 
agent. In particular, the requester process will typical- 
ly generate a data packet 146 that includes destina- 
tion data 148, a field 150 containing the alleged Auth 
ID of the principal on whose behalf the data packet is 
being sent, plus other packet header data 1 52 and the 
packet body 154. The destination data 148, whether 
included in the data packet or provided separately by 
the sending process, identifies the server node and 
process to which the data packet is being sent. For in- 
stance, the destination data 148 may comprise a 
node identifier and a process identifier. 

The authentication agent adds a subchannel val- 
ue 1 56 to the data packet 146 that corresponds to the 
requester and server processes, if no subchannel has 
previously been assigned to this pair of processes, a 
unique subchannel value is assigned and a new entry 
is added to the channel assignment table 144, and 
then the assigned subchannel value is added to the 
data packet If a subchannel has previously been pre- 
viously been assigned to this pair of processes, the 
assigned subchannel is obtained from the channel 
assignment table 144 and then added to the data 
packet 146. The subchannel value field 156 uniquely 
identifies the secure channel over which the packet 
will be sent, in addition to identifying the sending and 
receiving processes. Therefore, directly or indirectly, 
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the subchannel field 156 includes a channel identifi- 
er. For instance, the subchannel field may contain a 
value used by the receiving node's network controller 
to determine which decryption key to use for decrypt- 
ing the data packet 

Local Auth ID Cache for Authentication Agent 
When a request message is sent from a requester 
principal to a server process, the authenticity of each 
request must be verified. The present invention modi- 
fies prior art authentication procedures by maintain- 
ing two types of "local caches" 160 and 164 (actually 
tables of data stored in memory) which identify re- 
questers whose previous request messages were au- 
thenticated. 

The local cache 160 for the authentication agent 
lists the channel, subchannel and Auth ID of each 
principal from whom messages have been received. 
The record 162 in the local cache 160 for each such 
principal also includes a principal identifier, creden- 
tials received from the principal's host computer that 
authenticate the principal's messages, and a time- 
stamp indicating a time limit on the validity of those 
credentials. 

When a message from a principal is authenticat- 
ed, a set of several credentials are sent to authenti- 
cate the message, include credentials authenticating 
the node, and credentials specific to the user. Each 
such credential has an associated time limitthat limits 
the validity of that credential. When an authentication 
agent receives a set of credentials for a particular re- 
quester, it stores in the corresponding record 162 a 
tlmestamp representing the shortest duration time 
limit associated with the received credentials. That is, 
each received credential is delivered with a time limit 
(e.g., a datum Indicating that the corresponding cre- 
dential is valid for N seconds), and the authentication 
agent converts those time duration limits into a time 
value to be compared during later attempts to use the 
record 162 with the computer's current time value 
(maintained by the computer in conjunction with its 
clock circuit 126). 

Local Auth ID Cache for Server Processes. In the 
preferred embodiment, each server process main- 
tains a local cache 164 in its own address space. As 
shown In Figure 8, each record 166 of the server proc- 
ess local cache identifies a requester principal from 
whom a request was previously received, the re- 
quester's Auth ID and the subchannel over which re- 
quest messages from that requester have been re- 
ceived, a timestamp indicating a time limit on the val- 
idity of the local cache entry, as well a list of the object 
ACL entries which the requester principal Is known to 
satisfy. 

As mentioned before, each object has an associ- 
ated access control list (ACL). Typically, each ACL 
1 36 contains a list of entries, each of which indicates 
the type of access allowed for a specified principal. 
As shown in Figure 9, an object's ACL 1 36 consists of 



a set of entries 1 70 for each distinct type of access as- 
sociated with the object For instance, if an object is 
a set of data, it is possible or even likely that some 
principals might have only read access while other 

5 principals are allowed both read and write access. 
Each entry 170 defines one principal or compound 
principal who is authorized to access the object. 

The concept of compound principals allows for 
virtually unlimited complexity in defining a requester 

10 or defining a party authorized to access an object. 
Compound principals, and their use in computer ac- 
cess control systems, are discussed extensively in 
pending patent applications Serial No. 07/589,923, 
filed September 28, 1990, entitled Compound Princi- 

15 pals in Access Control Lists, and Serial No. 
07/783,361, filed October 28, 1991, entitled Access 
Control Subsystem and Method for Distributed Com- 
puter System Using Compound Principals, both of 
which are hereby incorporated by reference. 

20 Authenticating Requests . Referring to the flow 
chart in Figure 10, whenever a request message is 
transmitted to a server process at another node, the, 
receiving node identifies the requester in terms of the 
channel over which the data packet was transmitted, 

25 plus the subchannel and Auth ID fields 156 and 150 
in the data packet Note that the while subchannel 
field 156 in the preferred embodiment includes both 
channel and subchannel values, in other embodi- 
ments the channel might be identified in other ways, 

30 with the resulting channel value being passed to the 
server process along with the received data packet 
In either case, ft is the responsibility of the server 
process to ensure that the subchannel value in the re- 
ceived message corresponds to the actual secure 

35 channel over which the request was received. 

In the preferred embodiment, the requester proc- 
ess creates the request message (step 200), includ- 
ing an alleged Auth ID value, and the authentication 
agent adds the channel and subchannel information 

40 to the corresponding data packet (step 202), based 
on the identities of the requester and server process- 
es between which the data packet Is being transmit- 
ted, before transmitting the request message data 
packet to the node associated with the requester ser- 

45 ver. Assuming that the packet arrives uncorrupted at 
its specified destination node, the data packet is de- 
livered into the address space of the specified server 
process (step 204), for example process B1 of node 
102-1. The server process B1 then checks its local 

so cache 164 to see there is already an entry for the re- 
quester, as identified by the "channel, subchannel, 
Auth ID" values associated with the received data 
packet (step 206). 

If the requester is not listed in the server's local 

55 cache 164, or if the entry 166 for the requester is no 
long valid (as determined by comparing the time- 
stamp value in the entry 1 66 with a current time value 
(maintained by the computer in conjunction with its 
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clock circuit 126), then the server process requests 
the authorization agent 134 for its node to authenti- 
cate the request message (step 208). Since the au- 
thentication agent 134 for the server's node may al- 
ready have received credentials for the requester in s 
a previous transaction, it looks for a record in its local 
cache matching the requester message's channel, 
subchannel and Auth ID (step 21 0). If the authentica- 
tion agent's local cache 160 contains a record match- 
ing the channel, subchannel, and subchannel associ- 10 
ated with the received message, and the timestamp 
value indicates that the record 162 for the requester 
is still valid, that means the request message is "pre- 
authenticated", in which case the authentication 
agent notifies the server process that the request 15 
message is authentic (step 212) and passes to the 
server process the timestamp and (optionally) the 
Principal ID for the requester. By including the Princi- 
pal ID of the requester in the server process' local 
cache 164, accessing objects using the requester's 20 
Principal ID is made more efficient. 

If the requester's Auth ID in not found in the au- 
thentication agent's local cache 160, then the au- 
thentication agent sends a request to the authentica- 
tion agent of the requester's node for credentials to 25 
authenticate the request message (step 214). The 
authentication agent of the requester's node checks 
the authenticity of the "channel, subchannel, Auth ID" 
values associated with the request message. The 
first step of this checking process is searching its 30 
channel assignment table 144 for the request process 
associated with the request message's channel and 
subchannel. The second step is searching the Auth 
ID Table 142 to see if the specified Auth ID value is 
assigned to a principal logged onto the process found 35 
in the channel assignment table 144. If the authenti- 
cation agent determines that the "channel, subchan- 
nel, Auth ID" values associated with the request mes- 
sage are valid, then-it sends to the authentication 
agent in the server node the Principal ID for the re- 40 
quester, plus the required credentials, using digital 
signing protocols well known to those skilled in the 
art, thereby authenticating the request message 
(step 21 5). If the requester node authentication agent 
determines that the "channel, subchannel, Auth ID" 45 
values associated with the request message are not 
valid, it sends a negative acknowledgement (nak 
message) back to the server node's authentication 
agent, which will then void the request message. 

Upon receipt of the required credentials, the ser- so 
ver node's authentication agent stores the creden- 
tials in a record 162 in its local cache 160 and notifies 
the server process that the request message is au- 
thentic (step 212). The server process then adds a re- 
cord 166 to its local cache 164 for the requester as- 55 
sociated with the now-authenticated request mes- 
sage and proceeds with execution of the requested 
tasks (step 216). 



Returning to step 206, if the requester is listed in 
the server's local cache 164, and the timestamp for 
the requester indicates that the previously received 
credentials for this requester are still valid, the server 
process proceed with execution of the requested 
tasks (step 218). During execution of these tasks, if 
the server process successfully gains access to any 
objects on behalf of the requester, the ACL entries 
satisfied by the requester are added by the server 
process to the requester's record in the server proc- 
ess's local cache (step 220). The storage of ACL en- 
tries known to be satisfied by a particular requester 
in the server's local cache can be used by the server 
process to expedite granting access to previously ac- 
cessed objects. 

The authentication agent 143 for each node will 
periodically check its local cache 160 for records with 
expired credentials, so that such records can be de- 
leted, along with the corresponding records in the 
server process local caches. 

While the present invention has been described 
with reference to a few specific embodiments, the de- 
scription is illustrative of the invention and is not to be 
construed as limiting the invention. Various modifica- 
tions may occur to those skilled in the art without de- 
parting from the true spirit and scope of the invention 
as defined by the appended claims. It should be noted 
that the authentication agent can be considered to be 
an abstraction representing various portions of an op- 
erating system, or even various secure programs, 
such as trusted applications, that run on top of the op- 
erating system, that performs the security functions 
of the above described invention. 



Claims 

1. In a distributed computer system (100) having a 
multiplicity of interconnected computers (1 02-I...- 
N), security apparatus comprising: 

a plurality of processes, each process run- 
ning on one of the multiplicity of computers, the 
plurality of processes including requester proc- 
esses (A1, A2) and server processes (BI...BN); 

secure channels (140) connecting ones of 
the multiplicity of computers on which respective 
ones of said requester processes are running to 
second ones of the multiplicity of computers on 
which respective ones of the server processes 
are running; and 

a multiplicity of authentication agents 
(134-L.134-N), each running in a trusted com- 
puting base (135) on a different one of the multi- 
plicity of interconnected computers, one of the 
multiplicity of authentication agents, running on 
one of the multiplicity of computers having at 
least one server process running thereon, includ- 
ing: 
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local cache means (160,164) for maintain- 
ing data identifying previously authenticated re- 
quests from ones of the requester processes run- 
ning on other ones of the multiplicity of intercon- 
nected computers; and 5 

received request authenticating means 
(162) for authenticating, on behalf of the at least 
one server process, a received request when 
data in the received request match the data main- 
tained by the local cache means, and for obtain- 10 
ing credentials authenticating the received re- 
quest when the first data in the received request 
does not match the data maintained by the local 
cache means. 

15 

2. Security apparatus as claimed in claim 1 , wherein 

each requester process includes means 
for generating a request for initiating transmission 
of the request over one of the secure channels to 
a specified one of the server processes; and 20 
each server process includes: 

cache means for maintaining its 
own local cache of data identifying previously au- 
thenticated requests received by the server proc- 
ess; and 25 

local authenticating means for au- 
thenticating a received request when the first 
data in the received request matches the data 
maintained by its own cache means, and for re- 
questing authentication of the received request 30 
by the authentication agent running on the same 
computer as the server process when the data In 
the received request does not match the data 
maintained by its own cache means. 

35 

3. Security apparatus as claimed in claim 1 or 2, 
wherein 

the local cache means include means for 
time limiting validity of the data identifying previ- 
ously aut h e nticated requests; 40 

the received request authenticating 
means including means for not matching data in 
the received request match with invalid data in 
the local cache means. 

45 

4. In a distributed computer system (100) having a 
multiplicity of interconnected computers (102- 
I...102-N), security apparatus comprising: 

a plurality of processes, each process run- 
ning on one of the multiplicity of computers, the so 
plurality of processes including requester proc- 
esses (A1 A2) and server processes (BI...BN); 

secure channels (140) connecting first 
ones of the multiplicity of computers on which re- 
spective ones of the requester processes are 55 
running to second ones of the multiplicity of com- 
puters on which respective ones of the server 
processes are running; 



a plurality of authentication agents (134- 
I...134-N), each running in a trusted computing 
(135) base on a different one of the multiplicity of 
interconnected computers, each requester proc- 
ess Including means for generating a request and 
for initiating transmission of the request over one 
of the secure channels to a specified one of the 
server processes, the request including a first da- 
tum allegedly identifying a principal associated 
with the requester process; 

each authentication agent running on one 
of the multiplicity of interconnected computers 
having at least one requester process running 
thereon including: 

request processing means for adding a 
second datum to each request generated by a re- 
quester process running on the same one of the 
multiplicity of computers as the authentication 
agent, wherein the second datum uniquely corre- 
sponds to the originating requester process; and 

request authenticating means for authen- 
ticating that the first datum and second datum in . 
a previously sent request are valid; 

each authentication agent, running on one 
of the multiplicity of interconnected computers 
having at least one server process running there- 
on, including: 

local cache means (160,164) for maintain- 
ing data indicating the first datum and second da- 
tum in previously authenticated requests; and 

received request authenticating means 
(162) for authenticating, on behalf of the at least 
one server process, a received request when the 
first datum and second datum in the received re- 
quest match the data maintained by the local 
cache means, and for obtaining authentication of 
the received request from the authentication 
agent running on the same computer as the re- 
quester process that sent the received request 
when the first datum and second datum in the re- 
ceived request do not match the data maintained 
by the local cache means. 

5. Security apparatus as claimed in claim 4, wherein 
each server process includes: 

cache means for maintaining its 
own local cache of data indicating the first datum 
and second datum in previously authenticated re- 
quests received by the server process; and 

local authenticating means for au- 
thenticating a received request when the first da- 
tum and second datum in the received request 
match the data maintained by its own cache 
means, and for requesting authentication of the 
received request by t he aut hentication agent run- 
ning on the same computer as the server process 
when the first datum and second datum in the re- 
ceived request do not match the data maintained 
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by its own cache means. 

Security apparatus as claimed in claim 4 or 5, 
wherein the local cache means include means for 
time limiting validity of the data identifying previ- s 
ously authenticated requests; 

the received request authenticating 
means including means for not matching data in 
the received request match with invalid data in 
the local cache means. 10 

A method operating a distributed computer sys- 
tem (100) having a multiplicity of interconnected 
computers (102-1... 102-N), the steps of the meth- 
od comprising: 15 

running requester processes (A1 ,A2) on at 
least a first subset of the multiplicity of computers 
and running server processes (BL.BN) on at 
least a second subset of the multiplicity of com- 
puters; 20 

interconnecting with secure channels 
(140) first ones of the multiplicity of computers on 
which respective ones of the requester process- 
es are running to second ones of the multiplicity 
of computers on which respective ones of the 25 
server processes are running; 

establishing authentication agents (134- 
I... 134-N) within a trusted computing base (135) 
on each one of the multiplicity of computers; 

the requester processes each generating 30 
requests and initiating transmission of the re- 
quests over ones of the secure channels to spe- 
cified ones of the server processes, the requests 
each including a first datum allegedly identifying 
a principal associated with each requester proc- 35 
ess; 

said authentication agents adding to each 
request generated by the requester processes a 
second datum uniquely corresponding to the one 
of the requester processes which generated each 40 
request, those of the authentication agents es- 
tablished on ones of the multiplicity of computers 
having at least one server process running there- 
on: (A) maintaining a local cache of data indicat- 
ing t he first datum and second datum in previous- 45 
ly authenticated requests received by the at least 
one server process; (B) authenticating, on behalf 
of the at least one server process, a received re- 
quest when the first datum and second datum in 
the received request match the data in the local so 
cache; and (C) obtaining authentication of the re- 
ceived request, from the authentication agent es- 
tablished on the computer running the requester 
process that sent the received request, when the 
first datum and second datum in the received re- 55 
quest do not match the data maintained by t he lo- 
cal cache. 



8. A method as claimed in claim 7, wherein each 
server process maintains its own local cache of 
data indicating the first datum and second datum 
in previously authenticated requests received by 
the server process; and 

each server process self-authenticates a 
received request when the first datum and sec- 
ond datum in the received request match the data 
maintained by its own cache means, and re- 
quests authentication of the received request by 
the authentication agent running on the same 
computer as the server process when the first 
datum and second datum in the received request 
do not match the data maintained by its own 
cache means. 

9. A method as claimed in claim 7, 8 or 9, wherein 
the authentication agents time limit validity of the 
data maintained in said local cache for each the 
previously authenticated request; 

the authentication agents for not authen- 
ticating, on behalf of the at least one server proc- 
ess, a received request when the first datum and 
second datum in the received request match in- 
valid data in the local cache. 
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